package com.huangsm.cloud.filter;

import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
import com.netflix.zuul.exception.ZuulException;
import org.apache.commons.lang.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.ResponseBody;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.HashMap;
import java.util.Map;

/**
 * 自定义zuul过滤器
 *
 * @author huangsm
 * @version V1.0
 */
public class PreZuulFilter extends ZuulFilter {
    private static Logger log = LoggerFactory.getLogger(ZuulFilter.class);

    /**
     * pre：可以在请求被路由之前调用
     * route：在路由请求时候被调用
     * post：在route和error过滤器之后被调用
     * error：处理请求时发生错误时被调用
     *
     * @return
     */
    @Override
    public String filterType() {
        /**
         * 请求前被调用
         */
        return "pre";
    }

    /**
     * filterOrder：过滤的顺序
     * shouldFilter：这里可以写逻辑判断，是否要过滤，本文true,永远过滤。
     * run：过滤器的具体逻辑。可用很复杂，包括查sql，nosql去判断该请求到底有没有权限访问。
     *
     * @return
     */
    @Override
    public int filterOrder() {
        /**
         *
         */
        return 0;
    }

    /**
     * 是否执行过滤器，过滤器是否执行的开关
     * 如果有多个过滤器时，上一个过滤器返回为true,下一个过滤器需要执行，如果为false就没必要执行了
     *
     * @return
     */
    @Override
    public boolean shouldFilter() {
        /**
         * 此过滤器始终执行
         */
        return true;
        // return (boolean)RequestContext.getCurrentContext().get("isSuccess");

    }

    /**
     * 具体执行的逻辑
     *
     * @return
     * @throws ZuulException
     */
    @Override
    @ResponseBody
    public Object run() throws ZuulException {
        RequestContext requestContext = RequestContext.getCurrentContext();
        /**
         * 获取request
         */
        HttpServletRequest request = requestContext.getRequest();

        System.out.println(String.format("%s AccessPasswordFilter request to %s", request.getMethod(), request.getRequestURL().toString()));
        /**
         * 得到请求头的用户信息
         */
        String author = request.getHeader("author");

        /**
         * 假设的逻辑
         */
        if (StringUtils.isNotEmpty(author)) {
            /**
             * 对该请求进行路由
             */
            requestContext.setSendZuulResponse(true);
            requestContext.setResponseStatusCode(HttpStatus.OK.value());
            /**
             * 设置一个状态，下一个过滤器可能会用到的
             */
            requestContext.set("isSuccess", true);
            return null;
        } else {
            /**
             * 过滤该请求，不进行路由
             */
            requestContext.setSendZuulResponse(false);
            requestContext.setResponseStatusCode(HttpStatus.UNAUTHORIZED.value());
            Map json = new HashMap();
            json.put("msg", "用户令牌错误");
            /**
             *  返回前端内容
             */
            requestContext.setResponseBody(json.toString());
            HttpServletResponse response = requestContext.getResponse();
            response.setContentType(MediaType.APPLICATION_JSON_UTF8_VALUE);
            requestContext.set("isSuccess", false);
            return null;
        }
    }
}
